<script>
import { h } from 'vue'
export default {
  name: 'XtxBread',
  render(proxy) {
    // 用法
    /**
     * 1.template标签去除，单文件组件
     * 2.返回值就是组件内容
     * 3.vue2.0的h函数传参进来的，vue3.0h函数导入进来的
     * 4.h 第一个参数 标签名字  第二个参数 便签属性对象  第三个参数 子节点
     */
    // 需求
    /**
     * 1.创建xtx-bread父容器
     * 2.获取默认插槽内容
     * 3.去除xtx-bread-item组件的i标签，因该由render函数来组织
     * 4.遍历插槽中的item，得到一个动态节点，最后一个item不加i标签
     * 5.把动态创建的节点渲染到xtx-bread标签中
     */
    const slot = proxy.$slots.default()
    const arr = []
    slot.forEach((item, index) => {
      arr.push(item)
      if (index < slot.length - 1) {
        arr.push(h('i', { class: 'iconfont icon-angle-right' }))
      }
    })
    return h('div', { class: 'xtx-bread' }, arr)
  },
  setup() {
    return {}
  }
}
</script>
<style lang="less">
.xtx-bread {
  display: flex;
  padding: 25px 10px;
  &-item {
    a {
      color: #666;
      transition: all 0.4s;
      &:hover {
        color: @color;
      }
    }
  }
  i {
    font-size: 12px;
    margin-left: 5px;
    margin-right: 5px;
    line-height: 22px;
  }
}
</style>
